(fill-region, kill-region, delete-region)
authorRichard M. Stallman <rms@gnu.org>
Mon, 17 May 1993 04:45:03 +0000 (04:45 +0000)
committerRichard M. Stallman <rms@gnu.org>
Mon, 17 May 1993 04:45:03 +0000 (04:45 +0000)
(kill-ring-save): Use mark-active as enable condition.
(undo): Add an enable condition.

Fix up the edit commands.  Add fill-region.

lisp/menu-bar.el

index 126fb5bb7fcd6c371002c8623bffbc552d0da592..214b67a89a55b544758e662d8ea84adf391ee48d 100644 (file)
 (define-key menu-bar-file-menu [open-file] '("Open File..." . find-file))
 (define-key menu-bar-file-menu [new-frame] '("New Frame" . new-frame))
 
-(define-key menu-bar-edit-menu [clear] '("Clear" . x-delete-primary-selection))
-(define-key menu-bar-edit-menu [paste] '("Paste" . x-yank-clipboard-selection))
-(define-key menu-bar-edit-menu [copy] '("Copy" . x-copy-primary-selection))
-(define-key menu-bar-edit-menu [cut] '("Cut" . x-kill-primary-selection))
-(define-key menu-bar-edit-menu [undo] '("Undo" . advertised-undo))
+(define-key menu-bar-edit-menu [fill] '("Fill" . fill-region))
+(define-key menu-bar-edit-menu [clear] '("Clear" . delete-region))
+(define-key menu-bar-edit-menu [paste] '("Paste" . yank))
+(define-key menu-bar-edit-menu [copy] '("Copy" . kill-ring-save))
+(define-key menu-bar-edit-menu [cut] '("Cut" . kill-region))
+(define-key menu-bar-edit-menu [undo] '("Undo" . undo))
+
+(put 'fill-region 'menu-enable 'mark-active)
+(put 'kill-region 'menu-enable 'mark-active)
+(put 'kill-ring-save 'menu-enable 'mark-active)
+(put 'yank 'menu-enable '(x-selection-exists-p))
+(put 'delete-region 'menu-enable 'mark-active)
+(put 'undo 'menu-enable '(if (eq last-command 'undo)
+                            pending-undo-list
+                          (consp buffer-undo-list)))
 
 (define-key menu-bar-help-menu [emacs-tutorial]
   '("Emacs Tutorial" . help-with-tutorial))
 (put 'delete-frame 'menu-enable '(cdr (visible-frame-list)))
 (put 'kill-this-buffer 'menu-enable '(kill-this-buffer-enabled-p))
 
-(put 'x-kill-primary-selection 'menu-enable '(x-selection-owner-p))
-(put 'x-copy-primary-selection 'menu-enable '(x-selection-owner-p))
-(put 'x-yank-clipboard-selection 'menu-enable '(x-selection-owner-p))
-(put 'x-delete-primary-selection 'menu-enable
-     '(x-selection-exists-p 'CLIPBOARD))
-
 (put 'advertised-undo 'menu-enable
      '(and (not (eq t buffer-undo-list))
           (if (eq last-command 'undo)
@@ -193,18 +197,37 @@ and selects that window."
 ;;;           mode-name
 ;;;           (or (buffer-file-name) ""))))))
 \f
-;; Give all existing frames a menu bar.
-;; (Except for minibuffer-only frames.)
-(let ((frames (frame-list)))
-  (while frames
-    (or (eq 'only (cdr (assq 'minibuffer (frame-parameters (car frames)))))
-       (modify-frame-parameters (car frames) '((menu-bar-lines . 1))))
-    (setq frames (cdr frames))))
+(defvar menu-bar-mode nil)
+
+(defun menu-bar-mode (flag)
+  "Toggle display of vertical scroll bars on each frame.
+This command applies to all frames that exist and frames to be
+created in the future.
+With a numeric argument, if the argument is negative,
+turn off scroll bars; otherwise, turn on scroll bars."
+  (interactive "P")
+  (setq menu-bar-mode (if (null flag) (not menu-bar-mode)
+                         (or (not (numberp flag)) (>= flag 0))))
+  (let ((parameter (assq 'menu-bar-lines default-frame-alist)))
+    (if (consp parameter)
+       (setcdr parameter (if menu-bar-mode 1 0))
+      (setq default-frame-alist
+           (cons (cons 'menu-bar-lines (if menu-bar-mode 1 0))
+                 default-frame-alist))))
+  (let ((frames (frame-list)))
+    (while frames
+      ;; Turn menu bar on or off in existing frames.
+      ;; (Except for minibuffer-only frames.)
+      (or (eq 'only (cdr (assq 'minibuffer (frame-parameters (car frames)))))
+         (modify-frame-parameters
+          (car frames)
+          (list (if menu-bar-mode
+                    '(menu-bar-lines . 1)
+                  '(menu-bar-lines . 0)))))
+      (setq frames (cdr frames)))))
 
 ;; Make frames created from now on have a menu bar.
-(or (assq 'menu-bar-lines default-frame-alist)
-    (setq default-frame-alist
-         (cons '(menu-bar-lines . 1) default-frame-alist)))
+(menu-bar-mode t)
 
 (provide 'menu-bar)